<template>
	<view class="device-video">
		<view class="channel_wrap">
			<view class="item_body" v-for="(item, i) in channelList" :key="i"
				@click="gotoDevicePlayer(item.deviceSipId, item.channelId, item.status)">
				<view class="img">
					<image src="@/static/common/cameras.png" mode="widthFix" style="width: 200rpx;" class="play-icon">
					</image>
				</view>
				<view class="content">
					<view class="left_content">
						<u--text class="channel_name" :text="item.channelName"></u--text>
					</view>
					<view class="right_content">
						<u--text class="device_info" :text="'@'+item.model"></u--text>
					</view>
				</view>
				<view class="status">
					<u-tag v-if="item.statusInfo" :type="item.statusInfo.type" :plain="true" size="mini"
						:text="item.statusInfo.name"></u-tag>
				</view>
			</view>
		</view>
		<u-empty mode="data" :show="total === 0" marginTop="60" :text="$tt('scene.emptyData')"></u-empty>
	</view>
</template>

<script>
	import { relateChannelList } from '@/apis/modules/device.js';
	import { getSipStatusInfo } from '@/helpers/common.js';

	export default {
		name: "DeviceVideo",
		props: {
			device: {
				type: Object,
				default: null,
				required: true
			}
		},
		watch: {
			// 兼容小程序
			device: function(newVal, oldVal) {
				this.deviceInfo = newVal;
				this.isSubDev = newVal.subDeviceList && newVal.subDeviceList.length > 0;
				if (this.deviceInfo.sipRelationVOList) {
					this.getRelateChannelList();
				}
			}
		},
		data() {
			return {
				isSubDev: false,
				// 设备信息
				deviceInfo: {
					chartList: [],
				},
				//通道列表
				channelList: [],
				// 设备通道
				channelLoadStatus: 'nomore',
				queryParams: {
					deviceSipId: '', //设备sipid
				},
				total: 0,
			};
		},
		created() {
			// 获取设备状态(兼容H5和APP)
			if (this.device.subDeviceList) {
				this.deviceInfo = this.device;
				this.isSubDev = this.device.subDeviceList.length > 0;
			}
		},
		methods: {
			// 设备通道
			getRelateChannelList() {
				return new Promise((resolve, reject) => {
					relateChannelList(this.deviceInfo.deviceId).then(res => {
						if (res.code === 200) {
							this.channelList = res.data;
							this.total = res.data.length;
							res.data.map(item => {
								item.statusInfo = getSipStatusInfo(item.status);
								return item;
							})
							resolve(res.data);
						}
					}).catch(error => {
						reject(error);
					});
				});
			},
			gotoDevicePlayer(deviceSipId, channelSipId, status) {
				let statusInfo = getSipStatusInfo(status)
				if (status !== 3) {
					uni.showToast({
						icon: 'none',
						title: `无法查看${getSipStatusInfo(status).name}数据`
					});
					return;
				}
				// #ifdef H5
				uni.$u.route('/pages_player/list/devicePlayer', {
					deviceId: deviceSipId,
					channelSipId: channelSipId,
				});
				//#endif
				// #ifdef APP-PLUS 
				uni.$u.route('/pages_player/list/devicePlayerWebView', {
					deviceId: deviceSipId,
					channelSipId: channelSipId,
				});
				//#endif
				// #ifdef  MP-WEIXIN
				uni.$u.route('/pages_player/list/devicePlayerMpWeixin', {
					deviceId: deviceSipId,
					channelSipId: channelSipId,
				});
				//#endif
			},
		}
	}
</script>

<style lang="scss" scoped>
	.device-video {
		width: 100%;

		.channel_wrap {
			width: 100%;

			.item_body {
				position: relative;
				display: flex;
				flex-direction: column;
				align-items: center;
				background: #fff;
				border-radius: 20rpx;
				padding: 40rpx;

				&:not(:last-child) {
					margin-bottom: 20rpx;
				}

				.img {
					margin-top: 42rpx;
					padding: 40rpx 20rpx;
					display: flex;
					justify-content: center;
					align-items: center;
					width: 100%;
					height: 100%;
					background: linear-gradient(135deg, rgba(62, 135, 230, 0.3), rgba(0, 255, 255, 0.3)); // 渐变背景增强
					border-radius: 20rpx;
					margin-bottom: 30rpx;
					position: relative;
					overflow: hidden;

					.play-icon {

						transition: transform 0.3s ease;
					}

					&::before {
						content: '';
						position: absolute;
						top: 0;
						left: 0;
						width: 100%;
						height: 100%;
						background: radial-gradient(circle, rgba(255, 255, 255, 0.2), rgba(0, 0, 0, 0));
						opacity: 0;
						transition: opacity 0.4s ease;
					}

					&:hover::before {
						opacity: 1;
					}
				}

				.content {
					display: flex;
					justify-content: space-between;
					width: 100%;
					padding: 0 30rpx;

					.left_content {
						.channel_name {
							font-size: 34rpx;
							font-weight: bold;
							color: #333333;
							text-align: left;
						}
					}

					.right_content {
						.device_info {
							font-size: 28rpx;
							color: #777777;
							text-align: right;
						}
					}
				}

				.status {
					position: absolute;
					top: 20rpx;
					right: 20rpx;
				}
			}
		}

		.channel_wrap .item_body {
			transition: all 0.3s ease;
		}
	}
</style>